package br.com.atenas.sigop.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import br.com.atenas.sigop.dto.JogoDTO;

public class JogoDAO {
	private String tabela = " SIGOP.TB004_JOGO ";
	
	public void gravar(JogoDTO jogo, Connection conn) throws Exception{
		String sql = " INSERT INTO" + tabela +
		"(NU_MATERIAL, DE_TITULO, DE_ESTADO, DE_OBSERVACAO, QTD_JOGO, NU_TPMATERIAL) VALUES (?,?,?,?,?,?)";
		PreparedStatement ps = conn.prepareStatement(sql);
		int index = 1;
		preecherPK(jogo, conn);
		ps.setBigDecimal(index++, jogo.getNuMaterial());
		ps.setString 	(index++, jogo.getTitulo());
		ps.setString 	(index++, jogo.getEstado());
		ps.setString 	(index++, jogo.getObservacao());
		ps.setBigDecimal(index++, jogo.getQuantidade());
		ps.setBigDecimal(index++, jogo.getNuTpMaterial());
		ps.executeUpdate();
	}
	
	private void preecherPK (JogoDTO jogo, Connection conn)throws Exception{
		String sql = "select SQ004_JOGO.nextval from dual";
		PreparedStatement ps = conn.prepareStatement(sql);
		ResultSet rs = ps.executeQuery();
		rs.next();
		jogo.setNuMaterial(rs.getBigDecimal(1));
	}
	
	public List<JogoDTO> pesquisar(JogoDTO jogo, Connection conn) throws Exception{
		List<JogoDTO> jogos = new ArrayList<JogoDTO>();
		String sql = " SELECT NU_MATERIAL, DE_TITULO, DE_ESTADO, DE_OBSERVACAO, QTD_JOGO from" + tabela +
					 " WHERE DE_TITULO like ?";
		PreparedStatement ps = conn.prepareStatement(sql);
		ps.setString(1, jogo.getTitulo()+"%");
		
		ResultSet rs = ps.executeQuery();
		while(rs.next()){
			JogoDTO jogoResultado = new JogoDTO();
			jogoResultado.setNuMaterial	(rs.getBigDecimal("NU_MATERIAL"));
			jogoResultado.setTitulo		(rs.getString("DE_TITULO"));
			jogoResultado.setEstado		(rs.getString("DE_ESTADO"));
			jogoResultado.setObservacao	(rs.getString("DE_OBSERVACAO"));
			jogoResultado.setQuantidade	(rs.getBigDecimal("QTD_JOGO"));
			jogos.add(jogoResultado);
		}
		return jogos;
	}

	public void alterar(JogoDTO jogo, Connection conn) throws Exception{
		
		String sql = "UPDATE PUBLIC.SIGOPTB004_JOGO SET DE_TITULO = ?, DE_ESTADO = ?," +
					 " DE_OBSERVACAO = ?, QTD_JOGO = ? WHERE NU_MATERIAL = ?";  
		PreparedStatement ps = conn.prepareStatement(sql);
		int index = 1;
		ps.setString(index++, jogo.getTitulo());
		ps.setString(index++, jogo.getEstado());
		ps.setString(index++, jogo.getObservacao());
		ps.setBigDecimal(index++, jogo.getQuantidade());
		ps.setBigDecimal(index++, jogo.getNuMaterial());
		ps.executeUpdate();
		ps.close();
	}

	public void excluir(JogoDTO jogo, Connection conn) throws Exception{
		
		String sql = "DELETE FROM PUBLIC.SIGOPTB004_JOGO WHERE NU_MATERIAL = ?";
		PreparedStatement ps = conn.prepareStatement(sql);
		int index = 1;
		ps.setBigDecimal(index++, jogo.getNuMaterial());
		ps.executeUpdate();
		ps.close();
	}
}